Fast computation of linear equalizer coefficients from channel estimate

ABSTRACT

Computing optimal Linear Equalizer (LE) coefficients g opt  from a channel estimate h. A channel impulse response h is first estimated based upon either a known training sequence or an unknown sequence. The channel estimate is formulated as a convolution matrix H. The convolution matrix H is then related to the LE coefficients in a matrix format equation, the matrix format equation based upon the structure of the LE, the convolution matrix, and an expected output of the LE. A Fast Transversal Filter (FTF) algorithm is then used to formulate a recursive least squares solution to the matrix format equation. Computing the recursive least squares solution yields the LE coefficients using structured equations.

CROSS REFERENCES TO RELATED APPLICATIONS

This application is a continuation-in-part of U.S. Regular Utility application Ser. No. 10/044,013, filed Oct. 26, 2001, which claims priority to U.S. Provisional Application Ser. No. 60/322,994, filed Sep. 18, 2001, both of which are incorporated herein by reference in their entirety.

1. FIELD OF THE INVENTION

This invention relates generally to digital communications; and more particularly to linear equalizers.

2. BACKGROUND OF THE INVENTION

The structure and operation of communication systems is generally known. Many communication systems carry data, e.g., voice, audio, video, file, or other digital data that is sent from a transmitter to a receiver. On the transmitter side, data is first formed into packets. This data may be raw data or encoded data that represents the raw data. Each of these packets also typically includes a header, a known training sequence, and a tail. These packets are then modulated into symbols and the symbols are transmitted by the transmitter and intended for receipt by the receiver. The receiver then receives the symbols and attempts to extract the data that is carried by the symbols.

A “channel” carries the symbols from the transmitter to the receiver. The channel is serviced by a wired, wireless, optical, or another media, depending upon the communication system type. In many communication systems, such as terrestrial based wireless communication systems, satellite based communication systems, cable based communication systems, etc., the channel distorts the transmitted symbols, from the perspective of the receiver, causing interference between a subject symbol and a plurality of symbols surrounding the subject symbol. This type of distortion is referred to as “inter-symbol-interference” and is, generally speaking, the time-dispersed receipt of multiple copies the symbols caused by multipath. The channel also introduces noise into the symbols prior to their receipt. Each of these concepts is well known.

Equalizers are now generally employed in an attempt to remove channel effects from a received symbol stream. Thus, equalizers are essential building blocks of modern receivers, especially in broadband applications where inter-symbol-interference is a critical problem. In a typical equalizer, the channel between the transmitter and the receiver is first estimated based upon the training sequence contained in one or more preambles. Then optimal equalizer coefficients (also referred to as taps and/or tap coefficients for the equalizer) are estimated based upon the channel estimate. The optimal equalizer coefficients are then used by the equalizer in extracting the data from the packet. The optimal equalizer coefficients may also be computed after extraction of the data from the equalized data stream based upon blind channel estimates. Equalizer coefficient generation should be repeated as often as possible, especially in fast varying channel cases, to generate new equalizer coefficients. The received data stream is usually buffered during the period that is required for channel estimation and equalizer coefficient computations. Thus, the preamble (and also actual data) contained in a packet may be used to generate the channel estimate and optimal equalizer coefficients that are employed by the equalizer to extract the data from the packet.

As symbol rates increase and modulation schemes become more complex, equalizers have increasingly greater importance. A critical factor in increasing the effectiveness of these equalizers is the complexity of optimal equalizer coefficient computation. A reduction in this complexity: (1) reduces the memory size required to buffer the received symbol stream sequence during the period required for coefficient computations; (2) allows more frequent uploading of new coefficients thus enabling the equalizer to track fast channel variations; and (3) simplifies the hardware and, resultantly, the die area required for coefficient computation.

FIG. 1A is a block diagram illustrating a discrete time symbol-spaced Decision Feedback Equalizer (DFE) based channel equalization model 100. The channel equalization model 100 includes a channel 102, a Feed Forward Equalizer (FFE) 104, a Decision block 106, and a Feed Back Equalizer (FBE) 108. An input sequence x(n) is complex, independent, and identically distributed with unit power. Additive noise v(n) is white Gaussian with power spectral density v. Furthermore, the decisions {tilde over (x)}(n−δ) are assumed to be correct, and hence equal to x(n−δ). This assumption makes the design of the FBE 108 and FFE 104 easier, but at the expense of introducing error propagation due to possibly wrong decisions. The FFE 104 function G(z) has length L. The channel (impulse) response vector of the channel h is given in Equation (1) as: $\begin{matrix} {h\overset{\Delta}{=}\begin{bmatrix} {h(0)} & {h(1)} & \ldots & {h\left( {N - 1} \right)} \end{bmatrix}} & {{Equation}\quad(1)} \end{matrix}$ The number of coefficients (taps) M of the FBE 108 function B(z) is assumed greater or equal to the channel memory, i.e., M≧N−1. These modeling assumptions are feasible in practice.

In estimating FFE 104 and FBE 108 equalizer coefficients, the goal is to minimize the mean square error quantity of Equation (2). ζ=E|x(n−δ)−{circumflex over (x)}(n−δ)|²,  Equation (2) Where {circumflex over (x)}(n−δ) is the delayed input signal estimate prior to the Decision block 106. By collecting the coefficients of both G(z) and B(z) into vectors, we can express the received signal {circumflex over (x)}(n−δ) in Equation (3) as: x _(n) =y _(n) g−{tilde over (x)} _(n) b  Equation (3) A channel output model defining y_(n) may be expressed by: y _(n) =x _(n) H+v _(n)  Equation (4) where H is the (N+L−1)×L convolution matrix corresponding to the channel response and expressed as: $\begin{matrix} {H = \begin{bmatrix} {h(0)} & 0 & \cdots & 0 \\ {h(1)} & {h(0)} & \cdots & 0 \\ \vdots & \vdots & ⋰ & \vdots \\ {h\left( {N - 1} \right)} & {h\left( {N - 2} \right)} & ⋰ & {h(0)} \\ 0 & {h\left( {N - 1} \right)} & ⋰ & {h(1)} \\ \vdots & \vdots & ⋰ & \vdots \\ 0 & 0 & \cdots & {h\left( {N - 1} \right)} \end{bmatrix}} & {{Equation}\quad(5)} \end{matrix}$ In this model, x_(n) is the 1×(N+L−1) input vector, $\begin{matrix} {x_{n}\overset{\Delta}{=}\begin{bmatrix} {x(n)} & {x\left( {n - 1} \right)} & \ldots & {x\left( {n - N - L + 2} \right)} \end{bmatrix}} & {{Equation}\quad(6)} \end{matrix}$ y_(n) is the 1×L input regression vector to the FFE 104, $\begin{matrix} {y_{n}\overset{\Delta}{=}\begin{bmatrix} {y(n)} & {y\left( {n - 1} \right)} & \ldots & {x - {y\left( {n - L + 1} \right)}} \end{bmatrix}} & {{Equation}\quad(7)} \end{matrix}$ {tilde over (x)}_(n) is the 1×M input regression vector to the (strictly causal) FBE 108, $\begin{matrix} {{\overset{\Cup}{x}}_{n}\overset{\Delta}{=}\begin{bmatrix} {x\left( {n - \delta - 1} \right)} & {x\left( {n - \delta - 2} \right)} & \ldots & {x\left( {n - \delta - M} \right)} \end{bmatrix}} & {{Equation}\quad(8)} \end{matrix}$ and v_(n) is the 1×L vector noise process.

The current efficient methods for computing the optimal filter coefficients of a decision feedback equalizer, which optimizes (1), are based on the well-known Cholesky decomposition method (from a finite-dimension problem formulation). Two published papers: (1) N. Al-Dhahir and J. M. Cioffi, “MMSE Decision-Feedback Equalizers: Finite-Length Results,” IEEE Trans. on Information Theory, vol. 41, no. 4, pp. 961-973, July 1995; and (2) N. Al-Dhahir and J. M. Cioffi, “Fast Computation of Channel-Estimate Based Equalizers in Packet Data Transmission,” IEEE Trans. on Signal Processing, vol. 43, no. 11, pp. 2462-2473, November 1995 provide one procedure for computing optimal DFE settings. These equations are referred to hereinafter as “Al-Dhahir's equations.”

Generally speaking, Al-Dhahir's equations, as well as other existent techniques rely on the use of the generalized Schur algorithm for fast Cholesky decomposition of the matrices involved in both the FBE and FFE optimal coefficient setting computations. However, the overall procedures for calculation of the DFE (FBE and FFE) coefficients have the following problems:

-   -   1. These procedures require the use of nonstructured recursive         equations. These equations are difficult to implement from the         perspective of integrated circuit design. In particular, the         recursive equations used in Al-Dhahir's DFE tap (coefficient)         computer often requires the use of a DSP processor. As is         generally known, the use of a DSP processor in a real-time         communication system application is severely constricts system         throughput.     -   2. These procedures, in particular Al-Dhahir's equations require         a complex tap computer. In other words, they require the use of         a relatively large number of complex multiplies.     -   3. These prior art DFE coefficient computation techniques can be         used only for equalizers that use a fixed equalizer delay (δ),         which is set to its maximum value L−1, where L is the length of         the FFE 104. The prior art techniques cannot use a different         delay δ of the equalizer.

FIG. 1B is a block diagram illustrating a discrete time symbol-spaced Linear Equalizer (LE) channel equalization model 150. The LE channel equalization model 150 includes a channel 152 having length N, a LE 154 having length L, and a decision block 156. An input sequence x(n) is complex, independent, and identically distributed with unit power. Additive noise v(n) is white Gaussian with power spectral density σ_(v) ².

A minimization of the Mean Square Error (MSE) across the decision block 156 may be written as: $\begin{matrix} {\min\limits_{g}\quad{E{{{x\left( {n - \delta} \right)} - {y_{n} \cdot g}}}^{2}}} & {{Equation}\quad(9)} \end{matrix}$

Denoting R_(y) as the variance of the input regression vector y, and cross variance R_(yx(n−δ)), the smoothing problem for this minimization is given by Equation (10) as: g _(opt) =R _(y) ⁻¹ R _(yx(n−1)).  Equation (10)

A convolution matrix H as defined in Equation (5) may also be assumed for the LE channel equalization model 150. With a vector d defined as a vector of all zeros except for the δ^(th) element, which is unity, a solution for the coefficients of the LE 154 solution may be written as: $\begin{matrix} {g_{opt} = {\left\lbrack {{\sigma_{v}^{2}I} + {H^{*}H}} \right\rbrack^{- 1}H^{*}d}} & {{Equation}\quad(11)} \end{matrix}$

Prior art solutions of Equation (11) require matrix inversion. Such matrix inversion requires the greater of L³ or N³ multiplications and cannot be accomplished timely enough to allow a prior art transceiver to compute LE coefficients based upon a channel estimate. Accordingly, prior art techniques for training LEs included: (1) blindly assigning LE coefficients; (2) adapting the LE coefficients to a received preamble, training sequence, or other data; or (3) a combination of both of these techniques. Typically, convergence in training the LE using an iterative training approach, e.g., Least Squares, required a significant number of iterations. Oftentimes, such convergence in training could not be accomplished to meet the requirements of rapidly changing channels.

Thus, there is a need in the art for a technique to determine LE coefficients based upon a channel estimate.

SUMMARY OF THE INVENTION

In order to overcome the above-cited shortcomings, among others of the prior art, the method and system of the present invention computes optimal Linear Equalizer (LE) coefficients g_(opt) from a channel estimate h. As contrasted to the prior art, the methodology of the present invention relies on iterating simple structured recursions to yield the LE coefficients. Resultantly, the operation according to the present invention produces LE coefficients faster and with less computational requirements than the prior art operations, thus providing significant advantages over prior techniques.

According to the present invention, a channel impulse response h is first estimated based upon either a known training sequence or an unknown sequence. The channel estimate is formulated as a convolution matrix H. The convolution matrix H is then related to the LE coefficients in a matrix format equation, the matrix format equation based upon the structure of the LE, the convolution matrix, and an expected output of the LE. A Fast Transversal Filter (FTF) algorithm is then used to formulate a recursive least squares solution to the matrix format equation. The method concludes with computing the recursive least squares solution to yield the LE coefficients using structured equations.

In one particular embodiment, the recursive least squares solution is formulated as a Kalman gain solution using the FTF algorithm. In such embodiment, the Kalman gain solution may be determined using an Array Form Algorithm. The length of the LE may be chosen to force the Array Form Algorithm to use a lower triangular matrix. Further, the length of the LE may be chosen to force the FTF algorithm to use a lower triangular matrix.

The channel estimate is typically based upon a known preamble sequence of a data packet upon which the LE operates. After the LE coefficients have been determined, the LE may be used to equalize data received via the channel.

The method of the present invention is exact and may be employed to compute LE coefficients to track a rapidly fading channel. Because the method of the present invention relies upon simple structured recursion, the computation period and/or the hardware required for the LE coefficient computations may be implemented in both portable devices and non-portable devices. The method of the preset invention may be efficiently used in many communication systems that require the use of equalizers such as mobile wireless receivers, fixed wireless receivers, cable modem receivers, HDTV receivers, etc. to increase the performance of such communication systems. Other features and advantages of the present invention will become apparent from the following detailed description of the invention made with reference to the accompanying drawings.

BRIEF DESCRIPTION OF THE DRAWINGS

These and other features, aspects and advantages of the present invention will be more fully understood when considered with respect to the following detailed description, appended claims and accompanying drawings wherein:

FIG. 1A is a block diagram illustrating a discrete time symbol-spaced Decision Feedback Equalizer (DFE) channel equalization model;

FIG. 1B is a block diagram illustrating a discrete time symbol-spaced Linear Equalizer (LE) channel equalization model;

FIG. 2 is a logic diagram generally illustrating operation according to the present invention in determining DFE coefficients and applying such coefficients to a DFE;

FIG. 3 is a logic diagram illustrating operations according to the present invention employed to determine Feed Forward Equalizer (FFE) coefficients for the DFE;

FIG. 4 is a logic diagram illustrating operations according to the present invention employed to determine Feed Back Equalizer (FBE) coefficients for the DFE;

FIG. 5 is a block diagram illustrating a discrete time fractionally-spaced DFE that operates according to the present invention;

FIG. 6 is a block diagram illustrating a multi-channel equivalent of the discrete time fractionally-spaced DFE of FIG. 5;

FIG. 7 is a block diagram illustrating a transceiver having a DFE constructed according to the present invention;

FIG. 8 is a block diagram illustrating a transceiver having a LE constructed according to the present invention;

FIG. 9 is a logic diagram generally illustrating operation according to the present invention in determining LE coefficients and applying such coefficients to a LE; and

FIG. 10 is a logic diagram illustrating operations according to the present invention employed to determine LE coefficients.

DETAILED DESCRIPTION OF THE INVENTION

FIG. 2 is a logic diagram generally illustrating operation according to the present invention in determining Decision Feedback Equalizer (DFE) coefficients and in applying such coefficients to a DFE. The operations of the present invention are performed by a processor, such as a Digital Signal Processor (DSP), or other circuitry present within a receiver that determines DFE coefficients to be applied to a DFE, also resident in the receiver. The DFE operates upon samples of a received signal in an attempt to remove channel effects from the samples so that digital data may be extracted from the samples. The structure and operation of DFEs, one of which was illustrated in FIG. 1A, are generally known and will not be further described herein except as they relate to the present invention.

The operations of the present invention will be first performed by a processor, tap computer, DSP, or other receiver device, to determine initial DFE coefficients to be used in subsequent operations by the receiver. Thus, during startup or reset, a channel corresponding to the receiver is estimated (step 202). According to one embodiment of the present invention, the channel is estimated based upon a known preamble sequence. However, in other embodiments, the channel could also be estimated based upon unknown received data. In either case, channel estimation operations are generally well known and are not described further herein except as it relates to the present invention.

With the channel estimated, Feed Forward Equalizer (FFE) coefficients are determined based upon the channel estimate (step 206). Then, Feed Back Equalizer (FBE) coefficients are determined based upon the FFE coefficients and the channel estimate (step 208). The manner in which the FFE and FBE coefficients are generated is step 206 and step 208 will be described in detail herein with reference to FIGS. 3-7.

With the FFE and FBE coefficients determined, they are applied to the DFE (step 208) and are used in equalizing samples of a received signal to remove channel effects. These DFE coefficients are continually updated (step 210) using a known technique. Periodically, upon the receipt of a next packet for example, upon an indication that redetermination is required, or upon another triggering event, the DFE coefficients are redetermined (step 212). In this event, another channel estimate may be obtained (step 214). Then, the DFE coefficients are again determined according to the present invention and applied to the DFE. The operations of FIG. 2 continue until the receiver is turned off, placed in a sleep mode, or otherwise inactivated.

FIG. 3 is a logic diagram illustrating operations according to the present invention employed to determine Feed Forward Equalizer (FFE) coefficients for the DFE. In a first operation of FIG. 3, a DFE delay is selected (step 302). In one embodiment, this delay is selected as the channel length. In such case, the DFE delay corresponds to the length of the FFE.

Next, the DFE solution is formulated into a least squares solution (step 304). By collecting the FFE coefficients g and the FBE coefficients b into a single vector w, the minimization of the Mean Square Error may be written as: $\begin{matrix} {\min\limits_{w}\quad{E{{{x\left( {n - \delta} \right)} - {\underset{u}{\underset{︸}{\left\lbrack {y_{n} - {\overset{\Cup}{x}}_{n}} \right\rbrack}}\quad\underset{w}{\underset{︸}{\begin{bmatrix} g \\ b \end{bmatrix}}}}}}^{2}}} & {{Equation}\quad(12)} \end{matrix}$

Now, denoting R_(u) the variance of the augmented input regression vector u, and cross variance R_(ux(n−δ)), the well-known solution to this smoothing problem is given by Equation (13) as: w _(opt) =R _(u) ⁻¹ R _(ux(n−δ)).  Equation (13) where $\begin{matrix} {R_{u}\overset{\Delta}{=}{{{E\begin{bmatrix} y_{n}^{*} \\ {- {\overset{\Cup}{x}}_{n}^{*}} \end{bmatrix}}\left\lbrack {y_{n} - {\overset{\Cup}{x}}_{n}} \right\rbrack} = \begin{bmatrix} R_{y} & {- R_{y\overset{\Cup}{x}}} \\ {- R_{\overset{\Cup}{x}y}} & R_{\overset{\Cup}{x}} \end{bmatrix}}} & {{Equation}\quad(14)} \end{matrix}$ and $\begin{matrix} {R_{{ux}{({n - \delta})}} = {\begin{bmatrix} {E\quad y_{n}^{*}{x\left( {n - \delta} \right)}} \\ {E{\overset{\Cup}{x}}_{n}^{*}{x\left( {n - \delta} \right)}} \end{bmatrix} = \begin{bmatrix} R_{{yx}{({n - \delta})}} \\ R_{\overset{\Cup}{x}{x{({n - \delta})}}} \end{bmatrix}}} & {{Equation}\quad(15)} \end{matrix}$

Using the channel output model of Equation (4), and the fact that x(n) is individually identically distributed (i.i.d.), the following closed form expressions for {R_(y), R_(y{tilde over (x)}), R_({tilde over (x)}), R_(yx(n−δ)), R_({tilde over (x)}x(n−δ))} are determined: R _(y) =Ey _(n) *y _(n)=σ_(v) ²1+H*H  Equation (16) $\begin{matrix} {{R_{y\overset{\Cup}{x}} = {{H^{*}\left( {{Ex}_{n}^{*}{\overset{\Cup}{x}}_{n}} \right)} = {{H^{*}\begin{bmatrix} 0_{{({\delta + 1})}*M} \\ I_{M} \\ 0_{{({N + L - M - \delta})} \times M} \end{bmatrix}}\overset{\Delta}{=}{\overset{\_}{H}}^{*}}}},} & {{Equation}\quad(17)} \end{matrix}$  R_({tilde over (x)})=I_(M)  Equation (18) $\begin{matrix} {R_{{yx}{({n - \delta})}} = {{H^{*}{Ex}_{n}^{*}{x\left( {n - \delta} \right)}} = {{H^{*}\left\lbrack {0_{1 \times \delta}\quad 1\quad 0} \right\rbrack}^{T}\overset{\Delta}{=}h^{*}}}} & {{Equation}\quad(19)} \\ {R_{\overset{\Cup}{x}\quad{x{({n - \delta})}}} = 0} & {{Equation}\quad(20)} \end{matrix}$  R _({tilde over (x)}x(n−δ)) =0  Equation (20) where {overscore (H)} is a submatrix of H as set forth in Equation (5), $\begin{matrix} {H = \begin{bmatrix} H_{1} \\ \overset{\_}{H} \\ H_{2} \end{bmatrix}} & {{Equation}\quad(21)} \end{matrix}$ H₁ is defined as the (δ+1)×L submatrix of H, consisting of the first (δ+1) rows of H. Note that for the case of colored noise, the matrix σ_(v) ²I should be replaced by the autocorrelation matrix of the noise R_(v). Extending the derivation to the colored noise case is straightforward.

Now, with the quantities defined above, Equation (13) becomes: $\begin{matrix} {w_{opt} = {\begin{bmatrix} {{\sigma_{v}^{2}I} + {H^{*}H}} & {- {\overset{\_}{H}}^{*}} \\ {- \overset{\_}{H}} & I \end{bmatrix}^{- 1}\begin{bmatrix} h^{*} \\ 0 \end{bmatrix}}} & {{Equation}\quad(22)} \end{matrix}$ Using the well known inverse formula of block matrices, w_(opt) may be rewritten as: $\begin{matrix} {w_{opt} = {\left( {\begin{bmatrix} 0 & 0 \\ 0 & I \end{bmatrix} + {\begin{bmatrix} I \\ \overset{\_}{H} \end{bmatrix}{\left( {{\sigma_{v}^{2}I} + {H^{*}H} - {{\overset{\_}{H}}^{*}\overset{\_}{H}}} \right)^{- 1}\begin{bmatrix} I & \overset{\_}{H} \end{bmatrix}}}} \right)\begin{bmatrix} h^{*} \\ 0 \end{bmatrix}}} & {{Equation}\quad(23)} \end{matrix}$ and as: $\begin{matrix} {= {\begin{bmatrix} I \\ \overset{\_}{H} \end{bmatrix}\left( {{\sigma_{v}^{2}I} + {H_{1}^{*}H_{1}} + {H_{2}^{*}H_{2}}} \right)^{- 1}h^{*}}} & {{Equation}\quad(24)} \end{matrix}$ which may be written as: $\begin{matrix} {\begin{bmatrix} g_{opt} \\ b_{opt} \end{bmatrix} = {\begin{bmatrix} I \\ \overset{\_}{H} \end{bmatrix}\left( {{\sigma_{v}^{2}I} + {\left\lbrack {H_{1}^{*}\quad H_{2}^{*}} \right\rbrack\begin{bmatrix} H_{1} \\ H_{2} \end{bmatrix}}} \right)^{- 1}h^{*}}} & {{Equation}\quad(25)} \end{matrix}$

Although each of the two matrices H₁ and H₂ has a shift structure, the augmented matrix $\quad\begin{bmatrix} H_{1} \\ H_{2} \end{bmatrix}$ does not have a shift structure.

In selecting the length of the FBE (DFE delay) to be M≧N−1, the quantities h_(δ), H₁ and H₂ are such that: $\begin{matrix} {\left\lbrack \frac{H_{1}}{H_{2}} \right\rbrack = \left\lbrack \frac{H_{\delta}\quad 0}{0\quad\overset{\sim}{H}} \right\rbrack} & {{Equation}\quad(26)} \end{matrix}$ and h=[h _(δ)0]  Equation (27) This implies that: $\begin{matrix} {{{\sigma_{v}^{2}I} + {H_{1}^{*}H_{1}} + {H_{2}^{*}H_{2}}} = \begin{bmatrix} {{\sigma_{v}^{2}I} + {H_{\delta}^{*}H_{\delta}}} & 0 \\ 0 & {{\sigma_{v}^{2}I} + {{\overset{\sim}{H}}^{*}\overset{\sim}{H}}} \end{bmatrix}} & {{Equation}\quad(28)} \end{matrix}$ is block diagonal. In this case, the expressions for g_(opt) and b_(opt) decouple into a simple form. Therefore, the optimal FFE and FBE coefficients are represented as: g _(opt)=(σ_(ν) ² I+H _(δ) *H _(δ))⁻¹ H _(δ)*   Equation (29) b _(opt) ={overscore (H)}g _(opt)   Equation (30)

The above expressions are valid for all values of the DFE delay δ. In general, the optimal value for the DFE delay a is within the range L−1≦δ_(opt)≦N+L−2. In the special case of the choice δ=L−1, the matrices involved in the above expressions are given by $\begin{matrix} {{H_{\delta} = \begin{bmatrix} {h(0)} & 0 & \ldots & 0 \\ {h(1)} & {h(0)} & \ldots & 0 \\ \vdots & \vdots & ⋰ & \vdots \\ {h\left( {N - 1} \right)} & {h\left( {N - 2} \right)} & ⋰ & {h(0)} \end{bmatrix}},{h_{\delta}^{*} = \begin{bmatrix} {h^{*}\left( {N - 1} \right)} \\ {h^{*}\left( {N - 2} \right)} \\ \vdots \\ {h^{*}(0)} \end{bmatrix}}} & {{Equation}\quad(31)} \end{matrix}$ and $\begin{matrix} {H = \begin{bmatrix} 0 & {h\left( {N - 1} \right)} & ⋰ & {h(1)} \\ 0 & 0 & ⋰ & {h(2)} \\ \vdots & \vdots & ⋰ & \vdots \\ 0 & 0 & \cdots & {h\left( {N - 1} \right)} \end{bmatrix}} & {{Equation}\quad(32)} \end{matrix}$

Note that this solution is equivalent to the solution of Al-Dhahir's equations, due to the uniqueness of w_(opt) when Equation (2) is minimized. However, the expressions obtained above for Equations (29) and (30) provide alternative methods to compute the FFE and FBE coefficients g_(opt) and b_(opt) in a simpler and more efficient way than the prior art techniques.

In calculating g_(opt), a coefficient matrix is first defined in Equation (33) as: $\begin{matrix} {P_{\delta}\overset{\Delta}{=}\left( {{\sigma_{v}^{2}I} + {H_{\delta}^{*}H_{\delta}}} \right)^{- 1}} & {{Equation}\quad(33)} \end{matrix}$ so that the optimal solution for the FFE coefficients g_(opt) is given by g _(opt) =P _(δ) h _(δ)*.  Equation (34)

The expression for g_(opt) corresponds exactly to the definition of the Kalman gain vector, used to update the optimal weights in a certain regularized Recursive Least Squares (RLS) problem. More specifically, given a (n+1)×L data matrix H_(n) and the corresponding coefficient matrix P_(n), the Kalman gain g_(n)=P_(n)h_(n)* can be time-updated according to the following recursions: γ⁻¹(n)=1+h _(n) P _(n−1) h _(n)*,  Equation (35) g_(n) =P _(n−1) h _(n)*γ(n),  Equation (36) P _(n) =P _(n)−1−g _(n)γ⁻¹(n)g _(n)*,  Equation (37) where P⁻¹=σ_(v) ⁻²I (the term P⁻¹ is the initial condition for P_(n)) and g₀=0. The computation of the Kalman gain vector g_(n+1) in the above solution relies on the propagation of the Riccati variable P_(n). This method of computation requires O(L²) operations per iteration.

Well known fast RLS schemes avoid the propagation of P_(n) and compute the gain g_(n) in a more efficient way. In this case, the computational complexity required is only of O(L) per iteration. This implies that the overall complexity needed to calculate the FFE coefficients can be on the order of O(L²) thus yielding an efficient method for computing the FFE coefficients. Therefore, fast RLS filters are used to determine g_(opt). In such case, fast transversal computations are employed to determine the Kalman gain for the RLS solution (step 306). Here we also note that it is straightforward to extend this method to use other fast RLS algorithms, e.g., array form fast RLS algorithms.

Faster recursions may be obtained by selecting the FBE length. Such selection eliminates certain variables that remain constant and equal to zero during adaptations in the special solution for g_(opt). Fast RLS recursion in its explicit form propagates g_(n) in an efficient manner, see, e.g.: [1] Ljung, M. Morf, and D. Falconer, “Fast calculation of gain matrices for recursive estimation schemes,” Int. J. Contr. vol. 27, pp. 1-19, January 1978); [2] G. Carayannis, D. Manolakis, and N. Kalouptsidis, “A fast sequential algorithm for least squares filtering and prediction,” IEEE Trans. on Acoustic., Speech, Signal Proc., vol. ASSP-31, pp. 1394-1402, December 1983; and [3] J. Cioffi and T. Kailath, “Fast recursive-least-squares transversal filters for adaptive filtering,” IEEE Trans. on Acoust., Speech Signal Processing, vol. ASSP-32, pp. 304-337, April 1984.

Table 1 lists the fast recursions employed in one embodiment for computing the normalized Kalman gain. The additional index included in k_(L,n) and γ_(L)(n) stems from the fact that these quantities admit an order-update relation, instead of time-update. TABLE 1 Fast Transversal Computation of the Kalman gain. Initialization $\begin{matrix} {{\zeta^{f}\left( {- 1} \right)} = {{\zeta^{b}(0)} = \sigma_{v}^{2}}} \\ {w_{- 1}^{f} = {w_{0}^{b} = {k_{0} = 0}}} \\ {{\gamma_{L}(0)} = 1} \end{matrix}\quad$ For n =0 to δ repeat operations (1) to (13): $\begin{matrix} (1) & {{\alpha_{L}\left( {n - 1} \right)} = {{h(n)} - {h_{n - 1}w_{n - 2}^{f}}}} \\ (2) & {{f\left( {n - 1} \right)} = {{\gamma_{L}\left( {n - 1} \right)}{\alpha\left( {n - 1} \right)}}} \\ (3) & {k_{{L + 1},{n - 1}} = {\begin{bmatrix} 0 \\ k_{L,{n - 1}} \end{bmatrix} + {\frac{\alpha^{*}\left( {n - 1} \right)}{\zeta^{f}\left( {n - 2} \right)}\begin{bmatrix} 1 \\ {- w_{n - 2}^{f}} \end{bmatrix}}}} \\ (4) & {{\zeta^{f}\left( {n - 1} \right)} = {{\zeta^{f}\left( {n - 2} \right)} + {{\alpha^{*}\left( {n - 1} \right)}{f\left( {n - 1} \right)}}}} \\ (5) & {w_{n - 1}^{f} = {w_{n - 2}^{f} + {k_{L,{n - 1}}{f\left( {n - 1} \right)}}}} \\ (6) & {{\gamma_{L + 1}(n)} = {{\gamma_{L}\left( {n - 1} \right)}\frac{\zeta^{f}\left( {n - 2} \right)}{\zeta^{f}\left( {n - 1} \right)}}} \\ (7) & {{v(n)} = \left( {{last}\quad{entry}\quad{of}\quad k_{{L + 1},{n - 1}}} \right)} \\ (8) & {k_{L,n} = {{k_{{L + 1},{n - 1}}\left( {1:L} \right)} + {{v(n)}w_{n - 1}^{b}}}} \\ (9) & {{\beta(n)} = {{\zeta^{b}\left( {n - 1} \right)}{v^{*}(n)}}} \\ (10) & {{\gamma_{L}(n)} = \frac{\gamma_{L + 1}(n)}{1 - {{\gamma_{L + 1}(n)}{\beta_{L}(n)}{v_{L}(n)}}}} \\ (11) & {{b(n)} = {{\gamma_{L}(n)}{\beta_{L}(n)}}} \\ (12) & {{\zeta^{b}(n)} = {{\zeta^{b}\left( {n - 1} \right)} + {{\beta^{*}(n)}{b(n)}}}} \end{matrix}\quad$ Set g_(opt) = k_(L,δ)γ_(L)(δ).

The purpose of computing k_(n) in the well-known FTF algorithm is to use it in the computation of the corresponding optimal least squared solution for the FFE coefficients. Because we are interested only in k_(n), the filtering part of the FTF algorithm is not necessary, and does not appear in the algorithm listing.

The quantities {W_(n) ^(f),w_(n) ^(b)} are known as the least-squares solutions of the forward and backward prediction problems of order L, with corresponding residual errors {f(n),b(n)}. Now, because during the first L iterations, the desired signal for the backward prediction problem is equal to zero, the backward least squares solution w_(n) ^(b) will be equal to zero. This means that all quantities associated with the backward prediction problems will remain nulls for the first L iterations. Since in our case the optimal solution is achieved exactly at the L-th iteration, we can simply rule out the computation of these quantities from Table 1. These operations correspond to operations (7) and (9) through (13) of Table 1. Note that operation (10) of Table 1 is also eliminated, since β(n)=0, which implies γ_(L)(n)=γ_(L+1)(n). This means that we can replace operation (6) of Table 1 with: $\begin{matrix} {{{\gamma_{L}(n)} = {{\gamma_{L}\left( {n - 1} \right)}\frac{\zeta^{f}\left( {n - 2} \right)}{\zeta^{f}\left( {n - 1} \right)}}},} & {{Equation}\quad(38)} \end{matrix}$ which can be further simplified since $\begin{matrix} {{\gamma_{L}(n)} = {{\frac{\zeta^{f}\left( {- 1} \right)}{\zeta^{f}(0)}\frac{\zeta^{f}(0)}{\zeta^{f}(1)}\quad\cdots\quad\frac{\zeta^{f}\left( {n - 2} \right)}{\zeta^{f}\left( {n - 1} \right)}} = {\frac{\sigma_{v}^{2}}{\zeta^{f}\left( {n - 1} \right)}.}}} & {{Equation}\quad(39)} \end{matrix}$ Moreover, operation (8) of Table 1 becomes simply k _(L,n) =k _(L+1,n−1)(1:L).  Equation (40) where (1:L) denotes the first L entries of k_(L+1,n−1)

Table 2 illustrates a simplified fast recursion for computing the optimal FFE coefficients g_(opt). TABLE 2 Fast Transversal Computation of the FFE coefficients. Initialization $\begin{matrix} {{\zeta^{f}\left( {- 1} \right)} = \sigma_{v}^{2}} \\ {w_{- 1}^{f} = {k_{L,0} = 0}} \\ {{\gamma(0)} = 1} \end{matrix}\quad$ For n = 0 to δ repeat operations (1) through (7): $\begin{matrix} (1) & {{\alpha_{L}\left( {n - 1} \right)} = {{h(n)} - {h_{n - 1}w_{n - 2}^{f}}}} \\ (2) & {{f\left( {n - 1} \right)} = {{\gamma_{L}\left( {n - 1} \right)}{\alpha\left( {n - 1} \right)}}} \\ (3) & {k_{{L + 1},{n - 1}} = {\begin{bmatrix} 0 \\ k_{L,{n - 1}} \end{bmatrix} + {\frac{f^{*}\left( {n - 1} \right)}{\sigma_{v}^{2}}\begin{bmatrix} 1 \\ {- w_{n - 2}^{f}} \end{bmatrix}}}} \\ (4) & {{\zeta^{f}\left( {n - 1} \right)} = {{\zeta^{f}\left( {n - 2} \right)} + {{\alpha^{*}\left( {n - 1} \right)}{f\left( {n - 1} \right)}}}} \\ (5) & {w_{n - 1}^{f} = {w_{n - 2}^{f} + {k_{L,{n - 1}}{f\left( {n - 1} \right)}}}} \\ (6) & {{\gamma(n)} = \frac{\sigma_{v}^{2}}{\zeta^{f}\left( {n - 1} \right)}} \\ (7) & {k_{L,n} = {k_{{L + 1},{n - 1}}\left( {1:L} \right)}} \end{matrix}\quad$ Set g_(opt) = k_(L,δ)γ(δ)

With the Kalman gain determined, the FFE coefficients are then determined (step 308). In the recursions of Table 2, the FFE coefficients are determined by setting g_(opt)=k_(L,δ)γ(δ) when the number of iterations, n, is equal to the DFE delay.

Unlike the conventional weighted FTF algorithm, the above recursions do not face finite precision difficulties for the following reasons. First, by ruling out the equations associated with the backward prediction problem, we are automatically eliminating many of the recursive loops that are responsible for the finite precision difficulties of the full FTF algorithm. Second, these simplified fast recursions have a forgetting factor λ=1, which yields finite precision stability. Third, the simplified algorithm deals with a finite set of data (δ+1 iterations). This algorithm is then reset, which avoids the accumulation of finite precision errors.

FIG. 4 is a logic diagram illustrating operations according to the present invention employed to determine Feed Back Equalizer (FBE) coefficients for the DFE. The FBE coefficients b_(opt) are determined according to the matrix-vector product of Equation (30). The computation of the feedback filter coefficients simply amounts to convolution of the channel impulse response with g_(opt). The convolution operation that defines the optimal FBE coefficients in Equation (30) can be computed directly with LM/2 multiplications. Alternatively, the operations may also be efficiently performed using well-known fast FFT convolution techniques.

To illustrate such operations, Equation (32) is first rewritten in Equation (41) as: $\begin{matrix} {{b_{opt} = {{\left\lbrack {I_{M}\quad 0} \right\rbrack\begin{bmatrix} \overset{\_}{H} & H_{3} \\ H_{4} & H_{5} \end{bmatrix}}\begin{bmatrix} g_{opt} \\ 0 \end{bmatrix}}},} & {{Equation}\quad(41)} \end{matrix}$ The above equality holds true regardless of the values of H₃, H₄ or H₅. Now, if these values are chosen such that the matrix C, defined by: $\begin{matrix} {C = {\begin{bmatrix} \overset{\_}{H} & H_{3} \\ H_{4} & H_{5} \end{bmatrix}.}} & {{Equation}\quad(42)} \end{matrix}$ is a square (Q×Q) circulant matrix, where Q is the smallest power-of-two integer larger than or equal M+L. In this case, the matrix C is rewritten in Equation (43) as: C=F*ΛF,  Equation (43) where F is a (Q×Q) FFT matrix and A is a diagonal matrix that contains the elements of the FFT of the first row of C. The solution for b_(opt) becomes: $\begin{matrix} {{b_{opt} = {\begin{bmatrix} I_{M} & 0 \end{bmatrix}F*\Lambda\quad{F\begin{bmatrix} g_{opt} \\ 0 \end{bmatrix}}}},} & {{Equation}\quad(44)} \end{matrix}$ The complexity of this method is the complexity of obtaining the FFT of two vectors of Q elements of each, the inverse FFT of another Q element vector, and Q complex multiples. Thus the overall complexity is Q+3Q log₂(Q)  Equation (45) For the case of a power-of-two channel estimate N, the complexity is 2M+6M log₂(2M).  Equation (46)

Thus, referring again to FIG. 4, in determining the FBE coefficients, the convolutional matrix {overscore (H)} is first determined (step 402). As was previously described, the matrix {overscore (H)} may be determined as part of the channel estimation. Then, the convolutional matrix {overscore (H)} is extended to form the bigger circulant matrix C (step 404). The bigger circulant matrix C is then converted to the Frequency domain (step 406) as are the FFE coefficients (step 408). With both the bigger circulant matrix C and the FFE coefficients in the frequency domain, they are convolved in the frequency domain by simple matrix multiplication (step 410) to produce the FBE coefficients b_(opt). Finally, the resultant FBE coefficients b_(opt) are then converted to the time domain using inverse FFT operations to produce FBE coefficients b_(opt) in the time domain (step 412). The FBE coefficients b_(opt) are then applied with the FFE coefficients g_(opt) to the DFE (as previously described with reference to FIG. 2.

FIG. 5 is a block diagram illustrating a discrete time fractionally-spaced DFE that operates according to the present invention. FIG. 6 is a block diagram illustrating a multi-channel equivalent of the discrete time fractionally-spaced DFE of FIG. 5. The approach used for the symbol-spaced model can be easily extended to fractionally spaced models. In this section, we shall derive a fast algorithm for a T/2-spaced equalizer. The fast solution for the general case of faster oversampling factors, say T/3, T/4, . . . , etc. will then follow simply by inspection of the arguments in this section.

FIGS. 5 and 6 illustrate two equivalent representations for a discrete time model of a T/2-spaced equalizer. FIG. 5 illustrates a DFE 500 in terms of an down sampler and up sampler device, while FIG. 6 illustrates a DFE 600 is a corresponding multichannel representation. Thus, as contrasted to FIG. 1A, the DFE 500 of FIG. 5 includes a down sampler 502 and an up sampler 504 that alter the sampling frequency. Further, the DFE 600 of FIG. 6 includes a first channel function 602 having channel estimate h₀ and corresponding noise function v₀(n) and FFE 606 coefficients g₀. Likewise, the DFE 600 of FIG. 6 also includes a second channel function 604 having channel estimate h₁ and corresponding noise function v₁(n) and FFE 608 coefficients {g₀,g₁}.

The equivalence between the structures of FIG. 5 and FIG. 6 can be easily verified by writing each of the quantities {h.g} and v(n) in terms of their polyphase components, and interchanging their position with the down sampler and the up sampler (see, e.g., P. P. Vaidyanathan, “Multirate Systems and Filter Banks,” Prentice Hall, N.J., 1993 and J. R. Treichler, I. Fijalkow, C. R. Johnson, Jr., “Fractionally spaced equalizers,” IEEE Signal Processing Magazine, vol. 13, no. 3, May 1996 for details). The quantities {h₀,h₁} and {g₀,g₁} are the so-called polyphase components of the channel and FFEs, and are denoted by N and L size vectors {h₀,h₁} and {g₀,g₁} (see FIG. 6). The noise sequences {v₀(n),v₁(n)} are also the even and odd samples of v(n), with powers 2σ_(v) ².

A model for the multichannel representation, just like the one for the symbol spaced case in equation (4) may be rewritten by collecting {g₀,g₁} into a single vector g′, as: g′=[g ₁ g ₀]  Equation (47) with the output of the multichannel system given by: |y_(0,n)y_(1,n)|g′  Equation (48) Thus, the following model of Equation (49) works for the input to g′: |y _(0,n) t _(1,n) |=x _(n) [H ₀ H ₁ ]+[v _(0,n) v _(1,n)]  Equation (49) where {H₀,H₁} are the convolution matrices associated with the subchannels {h₀,h₁}. It is more convenient, however, to express the inner product in Equation (45) as a function of the original FFE coefficients vector g, by reordering the entries of g′. In this case, Equation (46) is replaced by: y′ _(n) =x _(n) H′+v′ _(n)  Equation (50) where $\begin{matrix} {H^{\prime} = \begin{bmatrix} {h(1)} & {h(0)} & \quad & \quad & \quad & \quad \\ {h(3)} & {h(2)} & {h(1)} & {h(0)} & \quad & \quad \\ \vdots & \vdots & {h(3)} & {h(2)} & \quad & \quad \\ {h\left( {{2N} - 1} \right)} & {h\left( {{2N} - 2} \right)} & \vdots & \vdots & ⋰ & {h(0)} \\ \quad & \quad & {h\left( {{2N} - 1} \right)} & {h\left( {{2N} - 2} \right)} & \quad & {h(2)} \\ \quad & \quad & \quad & \quad & ⋰ & \vdots \\ \quad & \quad & \quad & \quad & {h\left( {{2N} - 1} \right)} & {h\left( {{2N} - 2} \right)} \end{bmatrix}} & {{Equation}\quad(51)} \end{matrix}$ Given this convolution matrix and the noise variance σ_(v) ², the solution for the fractionally space problem is simply given by Equations (29) and (30), with {H_(δ),{overscore (H)},σ_(v) ²} replaced by {H′_(δ),{overscore (H)},σ_(v) ²} (similarly to the symbol-spaced case, here we assume M>N−1).

For the symbol-spaced DFE, the shift structure of H_(δ) implies that k_(L,n)=k_(L+1,n−1)(1:L). That is, the normalized gain k_(L,n) can be computed fast, by performing the order update of k_(L,n−1) to k_(L+1,n−1), and then retaining the first L entries of k_(L+1,n−1) as k_(L,n). The procedure to derive a fast recursion in the T/2-spaced case follows the same principle. The only difference here is that the data matrix H′_(δ) has now a double shift structure, in the sense that each row is formed by shifting two samples of the channel at a time. Thus, two successive order updates from k_(L,n−1) to k_(L+2,n−1) are performed and then the first L entries of k_(L+2,n−1) are retained: k_(L,n−1)→k_(L+1kn−1)→k_(L+2,n−1)  Equation (52) so that k _(L,n) =k _(L+2,n−1)(1:L)  Equation (53)

In other words, the resulting algorithm is given by two consecutive forward prediction problems similar to operations (1) through (6) of Table 2 of orders L and L+1, respectively. Table 3 lists the resulting algorithm for the T/2-spaced case. TABLE 3 Fast Transversal Computation of FFE coefficients for the T/2-spaced equalizer. Initialization ${\begin{matrix} {{\zeta_{L}^{f}\left( {- 1} \right)} = {{\zeta_{L + 1}^{f}\left( {- 1} \right)} = {2\sigma_{v}^{2}}}} \\ {w_{L,{- 1}}^{f} = {w_{{L + 1},{- 1}}^{f} = {k_{L,0} = {k_{{L + 1},0} = 0}}}} \\ {{\gamma_{L}(0)} = {{\gamma_{L + 1}(0)} = 1}} \end{matrix}\quad}\quad$ For n = 0 to δ repeat operations (I) to (II): (I) For q = L to L + 1 repeat operations (1) to (6): ${\begin{matrix} (1) & {{\alpha_{q}\left( {n - 1} \right)} = {{h\left( {{2n} + q - L + 1} \right)} - {h_{n - 1}w_{q,{n - 2}}^{f}}}} \\ (2) & {{f_{q}\left( {n - 1} \right)} = {{\gamma_{q}\left( {n - 1} \right)}{\alpha_{q}\left( {n - 1} \right)}}} \\ (3) & {k_{{q + 1},{n - 1}} = {\begin{bmatrix} 0 \\ k_{q,{n - 1}} \end{bmatrix} + {\frac{\alpha_{q}^{*}\left( {n - 1} \right)}{\zeta_{q}^{f}\left( {n - 2} \right)}\begin{bmatrix} 1 \\ {- w_{q,{n - 2}}^{f}} \end{bmatrix}}}} \\ (4) & {{\zeta_{q}^{f}\left( {n - 1} \right)} = {{\zeta_{q}^{f}\left( {n - 2} \right)} + {{\alpha_{q}^{*}\left( {n - 1} \right)}{f_{q}\left( {n - 1} \right)}}}} \\ (5) & {w_{q,{n - 1}}^{f} = {w_{q,{n - 2}}^{f} + {k_{q,{n - 1}}{f_{q}\left( {n - 1} \right)}}}} \\ (6) & {{\gamma_{q + 1}(n)} = {{\gamma_{q}(n)}\frac{\zeta_{q}^{f}\left( {n - 2} \right)}{\zeta_{q}^{f}\left( {n - 1} \right)}}} \end{matrix}\quad}\quad$ (II) k_(L,n) = k_(L+1),n−1(1:L) Set g_(opt) = k_(L,δ)γ_(L+2)(δ)

In the general case of a T/S spaced equalizer, the fast DFE tap computation is a straightforward extension of the above algorithm, where q is iterated from L to (L+S−1). However, in the fractionally spaced equalizer, the RLS problem is formulated as a multi-channel problem. In such case, a multi-channel Kalman gain is calculated for the multi-channel RLS problem and the FFE taps are determined therefrom. Note that in the expressions of Table 3, successive order updates are performed.

Now, the optimal FBE taps could now be computed as $\begin{matrix} {b_{opt} = {\begin{bmatrix} I_{M} & 0 \end{bmatrix}F*{\Lambda\quad}_{S}{\left( {F \otimes I_{S}} \right)\begin{bmatrix} g_{opt} \\ 0 \end{bmatrix}}}} & {{Equation}\quad(54)} \end{matrix}$ where Λ_(s) is a block diagonal matrix, which satisfies C _(S) =F _(S)*Λ_(S) F _(S)  Equation (55) where F_(S)=F⊕I_(S) and C_(S) is a block circulant matrix, which is formed by extending the matrix H in the same manner as in Equation (42). As was the case with the symbol spaced operations described above, the convolution may be performed in a transformed domain, e.g., Frequency Transformation domain, Discrete Cosine Transformation domain and the Discrete Hadamard Transformation domain, among others. In such case a Croniker product may be employed in conjunction with such domain transformation in performing multi-channel convolution in the selected transformed domain.

FIG. 7 is a block diagram illustrating a transceiver constructed according to the present invention. The components of the transceiver 700 are resident in a communications device and are illustrated only generally to show how the operations of the present invention would be accomplished in such a transceiver. The transceiver 700 includes a receiver section 702 and a transmitter section 704 and further includes either a wireless transceiver 706 or a wired transceiver, depending upon the system in which the transceiver 700 is implemented. In the case of a cellular device, RF device, satellite system device, or another wireless implementation, the transceiver 700 includes a wireless transceiver. However, in the case of a cable modem, a LAN device, a home networking device, or another device that couples to a physical media, the transceiver 700 includes a wired transceiver 708. Further, if the present invention is implemented in a Serializer/Deserializer (SERDES) or similar application, the receiver section 702 and transmitter section 704 may couple to a media without a wired transceiver 708.

Further discussion of the transmitter section 704 and receiver section 702 are in the context of baseband processing. In such case, the receiver section 702 receives a baseband signal from the wireless transceiver 706 (or wired transceiver 708) that is baseband modulated and operates upon the baseband signal to extract data. These operations include determining DFE coefficients according to the present invention and operating upon the baseband signal using the determined DFE coefficients.

The transmitter section 704 receives digital data to be transmitted from a host, codes the digital data into a baseband signal, and passes the baseband signal to the RF transceiver 706. The RF transceiver 706 couples the baseband signal to an RF carrier to create an RF signal and transmits the RF signal to a receiving device across a wireless link.

The receiver section 702 receives a baseband signal that carries coded data from the RF transceiver 706. A Programmable Gain Amplifier (PGA) 712 adjusts the gain of the baseband signal and then provides the gain-adjusted baseband signal to an Analog-to-Digital Converter (ADC) 714 for sampling. The ADC 208 samples the gain adjusted baseband signal at a particular sampling frequency, f_(S)(that is the symbol clock frequency), to produce samples thereof.

A processor 710 couples to the output of the ADC 714 and analyzes a preamble sequence contained in each received physical layer frame. Based upon the preamble sequence, the processor 710 determines a gain to be applied to portions of the baseband signal corresponding to the data carrying portions of the frame and provides this gain to the PGA 712. Further, the processor 710 may also interact with the optional timing compensation section 716 to compensate for symbol timing and RF carrier mismatches.

The processor 710, based upon the preamble sequence (and based upon actual extracted data in some operations), also determines FFE 104 and FBE 108 coefficients. The manner in which these coefficients are determined was previously described in detail herein. Further, and as was also previously described, the processor 710 may estimate a channel and calculate DFE coefficients based upon unknown but assumed data content. After the processor 710 determines these coefficients, they are applied to the FFE 104 and FBE 108 for subsequent use in extracting data from the baseband signal.

The structure described in FIG. 7 may be embodied using various types of circuits formed using various manufacturing processes. For example, in one particular embodiment, the RF transceiver 706 (or wired transceiver 708) is embodied in a first integrated circuit that is coupled to a second integrated circuit that includes the transmitter section 704 and the receiver section 702, among other circuits. In another embodiment, the RF transceiver 706, the transmitter section 704 and the receiver section 702 are all formed on a single monolithic integrated circuit. These integrated circuits may be constructed in CMOS or another semiconductor technology, e.g., PMOS, NMOS, Bipolar, etc.

Further, the receiver section 702 of FIG. 7 may be constructed using various circuit elements/combinations. In one embodiment, all structures past the ADC 714 in the receiver section 702 are embodied using a Digital Signal Processor (DSP) or similar processing device. In another embodiment, dedicated signal path circuitry embodies each of the structural components of the receiver section 702, including the processor 710. While a DSP implementation would provide more flexibility, dedicated signal path circuitry would typically provide higher performance at a lower cost and with lower power consumption.

FIG. 8 is a block diagram illustrating a transceiver having a LE constructed according to the present invention. The components of the transceiver 800 are similar to or the same as are similarly named components in FIG. 7. The transceiver 800 includes a receiver section 802 and a transmitter section 804 and further includes either a wireless transceiver 806 or a wired transceiver, depending upon the system in which the transceiver 800 is implemented. In the case of a cellular device, RF device, satellite system device, or another wireless implementation, the transceiver 800 includes a wireless transceiver. However, in the case of a cable modem, a LAN device, a home networking device, or another device that couples to a physical media, the transceiver 800 includes a wired transceiver 808. Further, if the present invention is implemented in a Serializer/Deserializer (SERDES) or similar application, the receiver section 802 and transmitter section 804 may couple to a media without a wired transceiver 808.

The receiver section 802 receives a baseband signal that carries coded data from the RF transceiver 806. A Programmable Gain Amplifier (PGA) 812 adjusts the gain of the baseband signal and then provides the gain-adjusted baseband signal to an Analog-to-Digital Converter (ADC) 814 for sampling. The ADC 208 samples the gain adjusted baseband signal at a particular sampling frequency, f_(S)(that is the symbol clock frequency), to produce samples thereof.

A processor 810 couples to the output of the ADC 814 and analyzes a preamble sequence contained in each received physical layer frame. The processor 810 may be a LE coefficients processor, a general processor such as a microprocessor, Digital Signal Processor (DSP), a custom processor, or another processing device that performs the LE coefficient processing operations, among other operations. Based upon the preamble sequence, the processor 810 determines a gain to be applied to portions of the baseband signal corresponding to the data carrying portions of the frame and provides this gain to the PGA 812. Further, the processor 810 may also interact with the optional timing compensation section 816 to compensate for symbol timing and RF carrier mismatches.

The processor 810, based upon the preamble sequence, the LE 154 structure, and an expected preamble sequence, determines LE 154 coefficients. The manner in which these coefficients are determined will be described with reference to FIGS. 9 and 10. After the processor 810 determines the LE coefficients, they are applied to the LE 154 for subsequent use in extracting data from the baseband signal.

The structure described in FIG. 8 may be embodied using various types of circuits formed using various manufacturing processes. For example, in one particular embodiment, the RF transceiver 806 (or wired transceiver 808) is embodied in a first integrated circuit that is coupled to a second integrated circuit that includes the transmitter section 804 and the receiver section 802, among other circuits. In another embodiment, the RF transceiver 806, the transmitter section 804 and the receiver section 802 are all formed on a single monolithic integrated circuit. These integrated circuits may be constructed in CMOS or another semiconductor technology, e.g., PMOS, NMOS, Bipolar, etc.

Further, the receiver section 802 of FIG. 8 may be constructed using various circuit elements/combinations. In one embodiment, all structures past the ADC 814 in the receiver section 802 are embodied using a DSP or similar processing device. In another embodiment, dedicated signal path circuitry embodies each of the structural components of the receiver section 802, including the processor 810. While a DSP implementation would provide more flexibility, dedicated signal path circuitry would typically provide higher performance at a lower cost and with lower power consumption.

FIG. 9 is a logic diagram generally illustrating operation according to the present invention in determining LE coefficients and applying such coefficients to a LE. The operations of the present invention are performed by a processor, such as a DSP, or other circuitry present within a receiver that determines LE coefficients to be applied to a LE, also resident in the receiver. The LE operates upon samples of a received signal in an attempt to remove channel effects from the samples so that digital data may be extracted from the samples. The structure and operation of LEs, one of which was illustrated in FIG. 1B, are generally known and will not be further described herein except as they relate to the present invention.

The operations of the present invention will be first performed by a processor, tap computer, DSP, or other receiver device, to determine initial DFE coefficients to be used in subsequent operations by the receiver. Thus, during startup or reset, a channel corresponding to the receiver is estimated (step 902). According to one embodiment of the present invention, the channel is estimated based upon a known preamble sequence. With the channel estimated, LE coefficients are determined based upon the channel estimate (step 904). The LE coefficients are then applied to the LE (step 906) and are used in equalizing samples of a received signal to remove channel effects. These LE coefficients are continually updated (step 910) using a known technique. Periodically, upon the receipt of a next packet for example, upon an indication that redetermination is required, or upon another triggering event, the LE coefficients are redetermined (step 912). In this event, another channel estimate may be obtained (step 914). Then, the LE coefficients are again determined according to the present invention and applied to the LE. The operations of FIG. 9 continue until the receiver is turned off, placed in a sleep mode, or otherwise inactivated.

FIG. 10 is a logic diagram illustrating operations according to the present invention employed to determine LE coefficients. Operation commences with formulating the channel estimate as a convolution matrix H (step 1002). Operation continues with relating the convolution matrix H to the LE coefficients in a matrix format equation, the matrix format equation based upon the structure of the LE, the convolution matrix, and an expected output of the LE (step 1004). Operation continues with using a Fast Transversal Filter (FTF) algorithm to formulate a recursive least squares solution to the matrix format equation (step 1006). Operation concludes with computing the recursive least squares solution to yield the LE coefficients using structured equations (step 1008).

In one particular embodiment, the recursive least squares solution is formulated as a Kalman gain solution using the FTF algorithm. In such embodiment, the Kalman gain solution may be determined using an Array Form Algorithm. The length of the LE may be chosen to force the Array Form Algorithm to use a lower triangular matrix. Further, the length of the LE may be chosen to force the FTF algorithm to use a lower triangular matrix.

The channel estimate is typically based upon a known preamble sequence of a data packet upon which the LE operates. After the LE coefficients have been determined, the LE may be used to equalize data received via the channel.

The method of the present invention is exact and may be employed to compute LE coefficients to track a rapidly fading channel. Because the method of the present invention relies upon simple structured recursion, the computation period and/or the hardware required for the LE coefficient computations may be implemented in both portable devices and non-portable devices. The method of the preset invention may be efficiently used in many communication systems that require the use of equalizers such as mobile wireless receivers, fixed wireless receivers, cable modem receivers, HDTV receivers, etc. to increase the performance of such communication systems.

In one particular embodiment, the channel estimate is formulated as a convolution matrix H according to Equation (5). With this embodiment, the matrix format equation is formulated at step (1004) as: $\begin{matrix} {g_{opt} = {\left\lbrack {{\sigma_{v}^{2}I} + {H^{*}H}} \right\rbrack^{- 1}H^{*}d}} & {{Equation}\quad(56)} \end{matrix}$

-   -   Where:     -   H is the convolution matrix;     -   g_(opt) is a vector of the LE coefficients;     -   σ_(v) ² is the power spectral density of the channel estimate;     -   I is the identity matrix; and     -   d as a vector of all zeros except for the δ^(th) element, which         is unity, δ representing a system delay.

With this embodiment, using the FTF algorithm to formulate the recursive least squares solution to the matrix format equation (at step 1006) produces the operations illustrated in Table 4. TABLE 4 Fast Transversal Computation of the LE taps. Initialization ${{\begin{matrix} {{\zeta^{f}\left( {- 1} \right)} = {{\zeta^{b}(0)} = \sigma_{v}^{2}}} \\ {w_{- 1} = {w_{- 1}^{f} = {w_{- 1}^{b} = {k_{L,0} = 0}}}} \\ {{\gamma_{M}(0)} = 1} \end{matrix}\quad}\quad}\quad$ For n = 0 to N + L − 1 repeat operations (1) to (16): $\begin{matrix} (1) & {{\alpha_{L}\left( {n - 1} \right)} = {{h(n)} - {h_{n - 1}w_{n - 2}^{f}}}} \\ (2) & {{f\left( {n - 1} \right)} = {{\gamma_{L}\left( {n - 1} \right)}{\alpha\left( {n - 1} \right)}}} \\ (3) & {{\overset{\_}{k}}_{{L + 1},n} = {\begin{bmatrix} 0 \\ k_{L,{n - 1}} \end{bmatrix} + {\frac{\alpha*\left( {n - 1} \right)}{\zeta^{f}\left( {n - 2} \right)}\begin{bmatrix} 1 \\ {- w_{n - 1}^{f}} \end{bmatrix}}}} \\ (4) & {{\zeta^{f}\left( {n - 1} \right)} = {{\zeta^{f}\left( {n - 2} \right)} + {{\alpha^{*}\left( {n - 1} \right)}{f\left( {n - 1} \right)}}}} \\ (5) & {w_{n}^{f} = {w_{n - 1}^{f} + {k_{L,{n - 1}}{f\left( {n - 1} \right)}}}} \\ (6) & {{\gamma_{L + 1}(n)} = {{\gamma_{L}\left( {n - 1} \right)}\frac{\zeta^{f}\left( {n - 2} \right)}{\zeta^{f}\left( {n - 1} \right)}}} \\ (7) & {{v(n)} = \left( {{last}\quad{entry}\quad{of}\quad{\overset{\_}{k}}_{{L + 1},n}} \right)} \\ (8) & {k_{L,n} = {{\overset{\_}{k}}_{{1:L},n} + {{v(n)}w_{n - 1}^{b}}}} \\ (9) & {{\beta(n)} = {{\zeta^{b}\left( {n - 1} \right)}{v^{*}(n)}}} \\ (10) & {{\gamma_{L}(n)} = \frac{{\overset{\_}{\gamma}}_{L + 1}(n)}{1 - {{{\overset{\_}{\gamma}}_{L + 1}(n)}{\beta_{L}(n)}{v_{L}(n)}}}} \\ (11) & {{b(n)} = {{\gamma_{L}(n)}{\beta_{L}(n)}}} \\ (12) & {{\zeta^{b}(n)} = {{\zeta^{b}\left( {n - 1} \right)} + {{\beta^{*}(n)}{b(n)}}}} \\ (13) & {w_{n}^{b} = {w_{n - 1}^{b} + {k_{L,n}{b(n)}}}} \\ (14) & {{e_{a}(n)} = {{d(n)} - {h_{n - 1}w_{n - 1}}}} \\ (15) & {{e_{p}(n)} = {{\gamma_{L}(n)}{e_{a}(n)}}} \\ (16) & {w_{n} = {w_{n - 1} + {{e_{p}(n)}k_{L,n}}}} \end{matrix}\quad$ If n = N + L − 1 set g_(opt) = w_(n)

With this embodiment, for the values of n≦L−1, the variables corresponding to the backward prediction problem are all equal to zero, while the forward prediction variables are not.

For the values of L−1<n<N−1, the backward prediction variables are non-zero as well. For N−1<n<N+L−1, the forward prediction variables are equal to zero. Exploiting this fact, the complexity (C) of the algorithm (in terms of total number of multiplies) is C=7NL−2L ², for N>L  Equation (57) C=7NL−2L ², for N<L

Where N and L are the lengths of the channel and the LE, respectively. Such complexity is orders of magnitude lower than direct matrix inversion, which requires the greater of N³ or L³ multiplies, whichever is greater.

The structure and operation of the present invention may be employed in satellite communication systems, satellite television systems, HDTV systems, fixed wireless communication systems, mobile wireless communication systems, cable modem/television communication systems, home networking systems, wireless local area networking systems, wired local area networking systems, and many other types of communication systems. The present invention applies to all types of communication devices in which equalizers are employed to operate upon received signals.

The invention disclosed herein is susceptible to various modifications and alternative forms. Specific embodiments therefore have been shown by way of example in the drawings and detailed description. It should be understood, however, that the drawings and detailed description thereto are not intended to limit the invention to the particular form disclosed, but on the contrary, the invention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the present invention as defined by the claims. 

1. A method for directly computing Linear Equalizer (LE) coefficients from a channel estimate, the method comprising: formulating the channel estimate as a convolution matrix H; relating the convolution matrix H to the LE coefficients in a matrix format equation, the matrix format equation based upon the structure of the LE, the convolution matrix, and an expected output of the LE; using a Fast Transversal Filter (FTF) algorithm to formulate a recursive least squares solution to the matrix format equation; and computing the recursive least squares solution to yield the LE coefficients using structured equations.
 2. The method of claim 1, wherein the recursive least squares solution is formulated as a Kalman gain solution using the FTF algorithm.
 3. The method of claim 2, wherein the Kalman gain solution is determined using an Array Form Algorithm.
 4. The method of claim 3, wherein a length of the LE is chosen to force the Array Form Algorithm to use a lower triangular matrix.
 5. The method of claim 1, wherein a length of the LE is chosen to force the FTF algorithm to use a lower triangular matrix.
 6. The method of claim 1, wherein the matrix format equation comprises: g_(opt) = [σ_(v)²I + H^(*)H]⁻¹H^(*)d where: H is the convolution matrix; g_(opt) is a vector of the LE coefficients; σ_(v) ² is the power spectral density of the channel estimate; I is the identity matrix; and d as a vector of all zeros except for the δ^(th) element, which is unity, δ representing a system delay.
 7. The method of claim 6, wherein the system delay is a combination of a length of the channel and a length of the LE.
 8. The method of claim 1, wherein the channel estimate is based upon a known preamble sequence of a data packet upon which the LE operates.
 9. The method of claim 1, further comprising the LE using the LE coefficients to equalize received data.
 10. The method of claim 8, wherein the LE services at least one of a High Definition Television receiver, a Wireless Local Area Network receiver, and a Cellular Telephone receiver.
 11. A Linear Equalizer System comprising: a Liner Equalizer (LE) having an input that receives an uncompensated signal and an output; and a LE coefficients processor that is operable to: formulate the channel estimate as a convolution matrix H; relate the convolution matrix H to the LE coefficients in a matrix format equation, the matrix format equation based upon the structure of the LE, the convolution matrix, and an expected output of the LE; use a Fast Transversal Filter (FTF) algorithm to formulate a recursive least squares solution to the matrix format equation; and solve the recursive least squares solution to yield the LE coefficients.
 12. The Linear Equalizer System of claim 11, wherein the LE coefficients processor is operable to formulate the recursive least squares solution as a Kalman gain solution using the FTF algorithm.
 13. The Linear Equalizer System of claim 12, wherein the LE coefficients processor is operable to determine the Kalman gain solution using an Array Form Algorithm.
 14. The Linear Equalizer System of claim 13, the LE coefficients processor is operable to choose a length of the LE to force the Array Form Algorithm to use a lower triangular matrix.
 15. The Linear Equalizer System of claim 11, the LE coefficients processor is operable to choose a length of the LE to force the FTF algorithm to use a lower triangular matrix.
 16. The Linear Equalizer System of claim 11, wherein the matrix format equation comprises: g_(opt) = [σ_(v)²I + H^(*)H]⁻¹H^(*)d where: H is the convolution matrix; g_(opt) is a vector of the LE coefficients; σ_(v) ² is the power spectral density of the channel estimate; I is the identity matrix; and d as a vector of all zeros except for the δ^(th) element, which is unity, δ representing a system delay.
 17. The Linear Equalizer System of claim 16, wherein the system delay is a combination of a length of the channel and a length of the LE.
 18. The Linear Equalizer System of claim 11, wherein the channel estimate is based upon a known preamble sequence of a data packet upon which the LE operates.
 19. The Linear Equalizer System of claim 11, wherein the LE is operable to equalize received data using the LE coefficients.
 20. The Linear Equalizer System of claim 18, wherein the LE is operable to service at least one of a High Definition Television receiver, a Wireless Local Area Network receiver, and a Cellular Telephone receiver. 